<template>
  <div class="login-background-img">
    <!-- <AppLocalePicker class="absolute top-4 right-4 enter-x xl:text-gray-600" :showText="false" />
    <AppDarkModeToggle class="absolute top-3 right-7 enter-x" />
    <div class="aui-logo" v-if="!getIsMobile">
      <div>
        <h3>
          <img :src="logoImg" alt="jeecg" />
        </h3>
      </div>
    </div>
    <div v-else class="aui-phone-logo">
      <img :src="logoImg" alt="jeecg" />
    </div> -->
    <div v-show="type === 'login'" class="h-full w-full flex justify-center">
      <div class="h-full w-2/4 flex justify-center items-center flex-col" style="padding-right: 20px;">
        <div class="w-full flex justify-end">
          <div class="flex justify-center items-center flex-col">
            <div class="title flex items-center flex-col" style="margin-top: 30px;">
              <div>宁夏八通生源健康管理有限公司</div>
              <div style="margin-top: 15px;">八通生源云平台</div>
            </div>
            <div style="width: 40%;margin-top: 20px;">
              <img :src="logo">
            </div>
          </div>
        </div>

      </div>
      <div class="h-full flex items-center w-2/4">
        <div style="width: 350px;">
          <div class="aui-formBox">
            <div class="aui-formWell">
              <div class="aui-flex aui-form-nav investment_title">
                <div class="aui-flex-box" :class="activeIndex === 'accountLogin' ? 'activeNav on' : ''"
                  @click="loginClick('accountLogin')">{{ t("sys.login.signInFormTitle") }}
                </div>
                <!-- <div class="aui-flex-box" :class="activeIndex === 'phoneLogin' ? 'activeNav on' : ''"
                    @click="loginClick('phoneLogin')">{{ t('sys.login.mobileSignInFormTitle') }}
                  </div> -->
              </div>
              <div class="aui-form-box" style="height: 180px">
                <a-form ref="loginRef" :model="formData" v-if="activeIndex === 'accountLogin'"
                  @keyup.enter.native="loginHandleClick">
                  <div class="aui-account">
                    <div class="aui-inputClear">
                      <i class="icon icon-code"></i>
                      <a-form-item>
                        <a-input class="fix-auto-fill" :placeholder="t('sys.login.userName')"
                          v-model:value="formData.username" />
                      </a-form-item>
                    </div>
                    <div class="aui-inputClear">
                      <i class="icon icon-password"></i>
                      <a-form-item>
                        <a-input class="fix-auto-fill" type="password" :placeholder="t('sys.login.password')"
                          v-model:value="formData.password" />
                      </a-form-item>
                    </div>
                    <div class="aui-inputClear">
                      <i class="icon icon-code"></i>
                      <a-form-item>
                        <a-input class="fix-auto-fill" type="text" :placeholder="t('sys.login.inputCode')"
                          v-model:value="formData.inputCode" />
                      </a-form-item>
                      <div class="aui-code">
                        <img v-if="randCodeData.requestCodeSuccess" :src="randCodeData.randCodeImage"
                          @click="handleChangeCheckCode" />
                        <img v-else style="margin-top: 2px; max-width: initial" :src="codeImg"
                          @click="handleChangeCheckCode" />
                      </div>
                    </div>
                    <div class="aui-flex">
                      <div class="aui-flex-box">
                        <div class="aui-choice">
                          <a-input class="fix-auto-fill" type="checkbox" v-model:value="rememberMe" />
                          <span style="margin-left: 5px">{{ t("sys.login.rememberMe") }}</span>
                        </div>
                      </div>
                      <!-- <div class="aui-forget">
                          <a @click="forgetHandelClick"> {{ t('sys.login.forgetPassword') }}</a>
                        </div> -->
                    </div>
                  </div>
                </a-form>
                <a-form v-else ref="phoneFormRef" :model="phoneFormData" @keyup.enter.native="loginHandleClick">
                  <div class="aui-account phone">
                    <div class="aui-inputClear phoneClear">
                      <a-input class="fix-auto-fill" :placeholder="t('sys.login.mobile')"
                        v-model:value="phoneFormData.mobile" />
                    </div>
                    <div class="aui-inputClear">
                      <a-input class="fix-auto-fill" :maxlength="6" :placeholder="t('sys.login.smsCode')"
                        v-model:value="phoneFormData.smscode" />
                      <div v-if="showInterval" class="aui-code" @click="getLoginCode">
                        <a>{{ t("component.countdown.normalText") }}</a>
                      </div>
                      <div v-else class="aui-code">
                        <span class="aui-get-code code-shape">{{ t("component.countdown.sendText", [unref(timeRuning)])
                        }}</span>
                      </div>
                    </div>
                  </div>
                </a-form>
              </div>
              <div class="aui-formButton">
                <div class="aui-flex">
                  <a-button :loading="loginLoading" class="aui-link-login aui-flex-box" type="primary"
                    @click="loginHandleClick">
                    {{ t("sys.login.loginButton") }}
                  </a-button>
                </div>
                <!-- <div class="aui-flex">
                    <a class="aui-linek-code aui-flex-box" @click="codeHandleClick">{{ t('sys.login.qrSignInFormTitle')
                    }}</a>
                  </div>
                  <div class="aui-flex">
                    <a class="aui-linek-code aui-flex-box" @click="registerHandleClick">{{ t('sys.login.registerButton')
                    }}</a>
                  </div> -->
              </div>
            </div>
            <!-- <a-form @keyup.enter.native="loginHandleClick">
                <div class="aui-flex aui-third-text">
                  <div class="aui-flex-box aui-third-border">
                    <span>{{ t('sys.login.otherSignIn') }}</span>
                  </div>
                </div>
                <div class="aui-flex" :class="`${prefixCls}-sign-in-way`">
                  <div class="aui-flex-box">
                    <div class="aui-third-login">
                      <a title="github" @click="onThirdLogin('github')"><GithubFilled /></a>
                    </div>
                  </div>
                  <div class="aui-flex-box">
                    <div class="aui-third-login">
                      <a title="企业微信" @click="onThirdLogin('wechat_enterprise')"><icon-font class="item-icon" type="icon-qiyeweixin3" /></a>
                    </div>
                  </div>
                  <div class="aui-flex-box">
                    <div class="aui-third-login">
                      <a title="钉钉" @click="onThirdLogin('dingtalk')"><DingtalkCircleFilled /></a>
                    </div>
                  </div>
                  <div class="aui-flex-box">
                    <div class="aui-third-login">
                      <a title="微信" @click="onThirdLogin('wechat_open')"><WechatFilled /></a>
                    </div>
                  </div>
                </div>
              </a-form> -->
          </div>
        </div>
      </div>

      <!-- <div class="aui-content">
        <div class="aui-container">
          <div class="aui-form">
            <div class="aui-image">
              <div class="aui-image-text">
                <img :src="adTextImg" />
              </div>
            </div>
          
          </div>
        </div>
      </div> -->
    </div>
    <div v-show="type === 'forgot'" :class="`${prefixCls}-form`">
      <MiniForgotpad ref="forgotRef" @go-back="goBack" @success="handleSuccess" />
    </div>
    <div v-show="type === 'register'" :class="`${prefixCls}-form`">
      <MiniRegister ref="registerRef" @go-back="goBack" @success="handleSuccess" />
    </div>
    <div v-show="type === 'codeLogin'" :class="`${prefixCls}-form`">
      <MiniCodelogin ref="codeRef" @go-back="goBack" @success="handleSuccess" />
    </div>
    <!-- 第三方登录相关弹框 -->
    <ThirdModal ref="thirdModalRef"></ThirdModal>
  </div>
</template>
<script lang="ts" setup name="login-mini">
import { getCaptcha, getCodeInfo } from "/@/api/sys/user";
import { onMounted, reactive, ref, toRaw, unref } from "vue";
import codeImg from "/@/assets/images/checkcode.png";
import logo from "/@/assets/images/login-logo.png";
import { useUserStore } from "/@/store/modules/user";
import { useMessage } from "/@/hooks/web/useMessage";
import { useI18n } from "/@/hooks/web/useI18n";
import { SmsEnum } from "/@/views/sys/login/useLogin";
import ThirdModal from "/@/views/sys/login/ThirdModal.vue";
import MiniForgotpad from "./MiniForgotpad.vue";
import MiniRegister from "./MiniRegister.vue";
import MiniCodelogin from "./MiniCodelogin.vue";
import { useLocaleStore } from "/@/store/modules/locale";
import { useDesign } from "/@/hooks/web/useDesign";
import { useAppInject } from "/@/hooks/web/useAppInject";
import { createFromIconfontCN } from "@ant-design/icons-vue";
import { AppDarkModeToggle } from '/@/components/Application';
const { prefixCls } = useDesign("mini-login");
const { notification, createMessage } = useMessage();
const userStore = useUserStore();
const { t } = useI18n();
const localeStore = useLocaleStore();
const randCodeData = reactive<any>({
  randCodeImage: "",
  requestCodeSuccess: false,
  checkKey: null
});
const rememberMe = ref<string>("0");
//手机号登录还是账号登录
const activeIndex = ref<string>("accountLogin");
const type = ref<string>("login");
//账号登录表单字段
const formData = reactive<any>({
  inputCode: "",
  username: "admin",
  password: "123456"
});
//手机登录表单字段
const phoneFormData = reactive<any>({
  mobile: "",
  smscode: ""
});
const loginRef = ref();
//第三方登录弹窗
const thirdModalRef = ref();
//扫码登录
const codeRef = ref();
//是否显示获取验证码
const showInterval = ref<boolean>(true);
//60s
const timeRuning = ref<number>(60);
//定时器
const timer = ref<any>(null);
//忘记密码
const forgotRef = ref();
//注册
const registerRef = ref();
const loginLoading = ref<boolean>(false);
const { getIsMobile } = useAppInject();

defineProps({
  sessionTimeout: {
    type: Boolean
  }
});

/**
 * 获取验证码
 */
function handleChangeCheckCode() {
  formData.inputCode = "";

  randCodeData.checkKey = 1629428467008;
  getCodeInfo(randCodeData.checkKey).then((res) => {
    randCodeData.randCodeImage = res;
    randCodeData.requestCodeSuccess = true;
  });
}

/**
 * 切换登录方式
 */
function loginClick(type) {
  activeIndex.value = type;
}

/**
 * 账号或者手机登录
 */
async function loginHandleClick() {
  if (unref(activeIndex) === "accountLogin") {
    accountLogin();
  } else {
    //手机号登录
    phoneLogin();
  }
}

async function accountLogin() {
  if (!formData.username) {
    createMessage.warn(t("sys.login.accountPlaceholder"));
    return;
  }
  if (!formData.password) {
    createMessage.warn(t("sys.login.passwordPlaceholder"));
    return;
  }
  try {
    loginLoading.value = true;
    const { userInfo } = await userStore.login(
      toRaw({
        password: formData.password,
        username: formData.username,
        captcha: formData.inputCode,
        checkKey: randCodeData.checkKey,
        mode: "none" //不要默认的错误提示
      })
    );
    if (userInfo) {
      notification.success({
        message: t("sys.login.loginSuccessTitle"),
        description: `${t("sys.login.loginSuccessDesc")}: ${userInfo.realname}`,
        duration: 3
      });
    }
  } catch (error) {
    notification.error({
      message: t("sys.api.errorTip"),
      description: error.message || t("sys.login.networkExceptionMsg"),
      duration: 3
    });
    handleChangeCheckCode();
  } finally {
    loginLoading.value = false;
  }
}

/**
 * 手机号登录
 */
async function phoneLogin() {
  if (!phoneFormData.mobile) {
    createMessage.warn(t("sys.login.mobilePlaceholder"));
    return;
  }
  if (!phoneFormData.smscode) {
    createMessage.warn(t("sys.login.smsPlaceholder"));
    return;
  }
  try {
    loginLoading.value = true;
    const { userInfo }: any = await userStore.phoneLogin({
      mobile: phoneFormData.mobile,
      captcha: phoneFormData.smscode,
      mode: "none" //不要默认的错误提示
    });
    if (userInfo) {
      notification.success({
        message: t("sys.login.loginSuccessTitle"),
        description: `${t("sys.login.loginSuccessDesc")}: ${userInfo.realname}`,
        duration: 3
      });
    }
  } catch (error) {
    notification.error({
      message: t("sys.api.errorTip"),
      description: error.message || t("sys.login.networkExceptionMsg"),
      duration: 3
    });
  } finally {
    loginLoading.value = false;
  }
}

/**
 * 获取手机验证码
 */
async function getLoginCode() {
  if (!phoneFormData.mobile) {
    createMessage.warn(t("sys.login.mobilePlaceholder"));
    return;
  }
  const result = await getCaptcha({
    mobile: phoneFormData.mobile,
    smsmode: SmsEnum.FORGET_PASSWORD
  });
  if (result) {
    const TIME_COUNT = 60;
    if (!unref(timer)) {
      timeRuning.value = TIME_COUNT;
      showInterval.value = false;
      timer.value = setInterval(() => {
        if (unref(timeRuning) > 0 && unref(timeRuning) <= TIME_COUNT) {
          timeRuning.value = timeRuning.value - 1;
        } else {
          showInterval.value = true;
          clearInterval(unref(timer));
          timer.value = null;
        }
      }, 1000);
    }
  }
}

/**
 * 第三方登录
 * @param type
 */
function onThirdLogin(type) {
  thirdModalRef.value.onThirdLogin(type);
}

/**
 * 忘记密码
 */
function forgetHandelClick() {
  type.value = "forgot";
  setTimeout(() => {
    forgotRef.value.initForm();
  }, 300);
}

/**
 * 返回登录页面
 */
function goBack() {
  activeIndex.value = "accountLogin";
  type.value = "login";
}

/**
 * 忘记密码/注册账号回调事件
 * @param value
 */
function handleSuccess(value) {
  Object.assign(formData, value);
  Object.assign(phoneFormData, { mobile: "", smscode: "" });
  type.value = "login";
  activeIndex.value = "accountLogin";
  handleChangeCheckCode();
}

/**
 * 注册
 */
function registerHandleClick() {
  type.value = "register";
  setTimeout(() => {
    registerRef.value.initForm();
  }, 300);
}

/**
 * 注册
 */
function codeHandleClick() {
  type.value = "codeLogin";
  setTimeout(() => {
    codeRef.value.initFrom();
  }, 300);
}

onMounted(() => {
  //加载验证码
  handleChangeCheckCode();
});
</script>

<style lang="less" scoped>
@import '/@/assets/loginmini/style/home.less';
@import '/@/assets/loginmini/style/base.less';

.fixed-corner {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9999;
  /* 可选，用于设置元素的层级 */
}

.title {
  font-size: 27px;
  font-family: PingFangSC-Semibold, PingFang SC;
  font-weight: 600;
  color: rgba(0, 0, 0, 0.85);
  line-height: 27px;
}

:deep(.ant-input:focus) {
  box-shadow: none;
}

.aui-get-code {
  float: right;
  position: relative;
  z-index: 3;
  background: #ffffff;
  color: #1573e9;
  border-radius: 100px;
  padding: 5px 16px;
  margin: 7px;
  border: 1px solid #1573e9;
  top: 12px;
}

.aui-get-code:hover {
  color: #1573e9;
}

.code-shape {
  border-color: #dadada !important;
  color: #aaa !important;
}

:deep(.jeecg-dark-switch) {
  position: absolute;
  margin-right: 10px;
}

.aui-link-login {
  height: 42px;
  padding: 10px 15px;
  font-size: 14px;
  border-radius: 8px;
  margin-top: 15px;
  margin-bottom: 8px;
}

.aui-phone-logo {
  position: absolute;
  margin-left: 10px;
  width: 60px;
  top: 2px;
  z-index: 4;
}

.top-3 {
  top: 0.45rem;
}
</style>

<style lang="less">
// @prefix-cls: ~'@{namespace}-mini-login';
// @dark-bg: #293146;

// html[data-theme='dark'] {
//   .@{prefix-cls} {
//     background-color: @dark-bg !important;
//     background-image: none;

//     &::before {
//       background-image: url(/@/assets/svg/login-bg-dark.svg);
//     }

//     .aui-inputClear {
//       background-color: #232a3b !important;
//     }

//     .ant-input,
//     .ant-input-password {
//       background-color: #232a3b !important;
//     }

//     .ant-btn:not(.ant-btn-link):not(.ant-btn-primary) {
//       border: 1px solid #4a5569 !important;
//     }

//     &-form {
//       background: @dark-bg !important;
//     }

//     .app-iconify {
//       color: #fff !important;
//     }

//     .aui-inputClear input,
//     .aui-input-line input,
//     .aui-choice {
//       color: #c9d1d9 !important;
//     }

//     .aui-formBox {
//       background-color: @dark-bg !important;
//     }

//     .aui-third-text span {
//       background-color: @dark-bg !important;
//     }

//     .aui-form-nav .aui-flex-box {
//       color: #c9d1d9 !important;
//     }

//     .aui-formButton .aui-linek-code {
//       background: @dark-bg !important;
//       color: white !important;
//     }

//     .aui-code-line {
//       border-left: none !important;
//     }

//     .ant-checkbox-inner,
//     .aui-success h3 {
//       border-color: #c9d1d9;
//     }
//   }

//   input.fix-auto-fill,
//   .fix-auto-fill input {
//     -webkit-text-fill-color: #c9d1d9 !important;
//     box-shadow: inherit !important;
//   }

//   &-sign-in-way {
//     .anticon {
//       font-size: 22px !important;
//       color: #888 !important;
//       cursor: pointer !important;

//       &:hover {
//         color: @primary-color !important;
//       }
//     }
//   }

//   .ant-divider-inner-text {
//     font-size: 12px !important;
//     color: @text-color-secondary !important;
//   }

//   .aui-third-login a {
//     background: transparent;
//   }
// }
</style>
